存储过程实现(可带查询条件/万能分页/通用)
+ @fldName + '] from [' + @tblName + ']' + @strOrder + ') as tblTmp)'
@OrderType = 1, -- bit
set @strTmp =''
end
@PageIndex = 1, -- int
+ @tblName + ']' + @strTmp + ' ' + @strOrder
begin
复制代码 代码如下:
假设数据库中有张表,表名是UserName,字段分别是ID(int),Name(nvarchar),Age(int)。CREATE PROCEDURE [dbo].[UP_GetRecordByPage]
if @strWhere != ''
end
@fldName varchar(255), -- 主键字段名
@OrderType bit, -- 设置排序类型, 非 0 值则降序
else
下面十二个万能分页存储过程,
AS
declare @strTmp varchar(2000) -- 临时变量(查询条件过长时可能会出错,可修改100为1000)
select ID,Name,Age from myTable where rownum between @min and @max
end
@strWhere = 'Age=13' -- varchar(1000)
+ @tblName + '] where [' + @fldName + ']' + @strTmp + '(['
if @IsReCount != 0
+ @strOrder
set @strOrder = ' order by [' + @fldName +'] desc'
+ @strOrder + ') as tblTmp) and ' + @strWhere + ' ' + @strOrder
set @strSQL = 'select top ' + str(@PageSize) + ' * from ['
@IsReCount = 0, -- bit
@pageIndex int,
@PageSize int , -- 页尺寸
@fldName = 'ID', -- varchar(255)
end
@PageSize = 2, -- int
with myTable as(select ID,Name,Age,Row_Number() over (order by ID) as rownum from [UserName] )
set @strTmp = ' where ' + @strWhere
set @strOrder = ' order by [' + @fldName +'] asc'
复制代码 代码如下:
这个分页存储过程很不实用,并且表是固定的。+ @fldName + ']) from (select top ' + str((@PageIndex-1)*@PageSize) + ' ['
exec (@strSQL)
@strWhere varchar(1000) = '' -- 查询条件 (注意: 不要加 where)
set @strSQL = 'select top ' + str(@PageSize) + ' * from ['
if @OrderType != 0
declare @strSQL varchar(6000) -- 主语句
set @strSQL = 'select count(*) as Total from [' + @tblName + ']'+' where ' + @strWhere
begin
EXEC dbo.UP_GetRecordByPage @tblName = ‘UserName', -- varchar(255)
@PageIndex int , -- 页码
set @strSQL = 'select top ' + str(@PageSize) + ' * from ['
@tblName varchar(255), -- 表名
@pageSize int
set @strTmp = '<(select min'
CREATE PROCEDURE [dbo].[UserName]
if @PageIndex <> 0
begin
@IsReCount bit, -- 返回记录总数, 非 0 值则返回
if @strWhere != ''
set @strTmp = '>(select max'
RETURN
+ @fldName + '] from [' + @tblName + '] where ' + @strWhere + ' '
declare @max int;
declare @min int;
复制代码 代码如下:
如果不带查询条件存储过程是:exec (@strSQL)
declare @strOrder varchar(400) -- 排序类型
set @min=@pageSize*(@pageIndex-1)+1;
begin
AS
set @max=@pageSize*@pageIndex;
如果哪里有不正确的地方,欢迎批评指正,共同进步。
相关热词: 分页
本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供用于网络技术学习参考,学习中请遵循相关法律法规!
本文地址: https://v30.fanwenzhu.com/sql/mssql/2837.shtml
相关文章
热门TAG
win10 ecshop 主机 阿里云 解决 配置 C# C++ 解析 SQL语句 命令 Go语言 方法 CSS3 HTML5 CSS win7 MSSQL 服务器配置 IIS7.5 IIS7 IIS6 IIS CentOS 7 Linux oracle数据库 oracle phpcms discuz discuz教程最新文章
-
SQL基本教程之行转列Pivo
时间:2021-01-20
-
region from hr.Employees union
时间:2021-01-20
-
有时候需要调整用户权限
时间:2021-01-19
-
(但使用 ORDER BY 子句并不
时间:2021-01-19
-
RAND()*10000)insert into Detail
时间:2021-01-19
-
OR 运算符:在两侧的查询
时间:2021-01-19
-
放假之前老大跟我提起了
时间:2021-01-19
-
数据库的运维计策剧本篇
时间:2021-01-19
热门文章
-
4.与聚合函数和 GROUP BY 子句有关的常见错
时间:2021-01-19
-
SQL Server安全(11/11):审核(Auditing)
时间:2021-01-09
-
sqlserver中查询横表变竖表的sql语句简析
时间:2020-12-08
-
SQL Server简单模式下误删除堆表记录恢复方
时间:2020-12-12
-
关于SQL Server查询语句的使用
时间:2020-12-13
-
MSSQL教程_mssql数据库教程_MSSQL基础教程_第
时间:2020-12-13
-
jdbc连接sql server数据库问题分析
时间:2020-12-10
-
详解SQL游标的用法
时间:2020-12-27
-
sql server 关于设置null的一些建议
时间:2020-12-28
-
mssql关于一个表格结构的另外一种显示(表
时间:2020-12-11
